from django.shortcuts import render
from django.conf import settings
from rest_framework.response import Response
from rest_framework.views import APIView
from .utils import QQOauth
from urllib.parse import urlencode,parse_qs
from urllib.request import urlopen
from oauth.models import OAuthQQUser
from .serializers import OauthQQSerializer
from rest_framework_jwt.settings import api_settings

# Create your views here.
class OauthQQURLView(APIView):
    """
        # 生成auth_url
        # https://graph.qq.com/oauth2.0/authorize
        # 请求参数请包含如下内容：
        # response_type   必须      授权类型，此值固定为“code”。
        # client_id       必须      申请QQ登录成功后，分配给应用的appid。
        # redirect_uri    必须      成功授权后的回调地址，必须是注册appid时填写的主域名下的地址，建议设置为网站首页或网站的用户中心。注意需要将url进行URLEncode。
        # state           必须      client端的状态值。用于第三方应用防止CSRF攻击，成功授权后回调时会原样带回。请务必严格按照流程检查用户与state参数状态的绑定。
        # scope              可选      scope=get_user_info
    """
    def get(self,request):

        qq = QQOauth()

        auth_url = qq.get_oauth_url()

        return Response({'auth_url':auth_url})


class OauthQQView(APIView):
    """
     GET  通过code 获取token
    """

    def get(self,request):

        # PC网站：https://graph.qq.com/oauth2.0/token
        # GET
        # grant_type      必须      授权类型，在本步骤中，此值为“authorization_code”。
        # client_id       必须      申请QQ登录成功后，分配给网站的appid。
        # client_secret   必须      申请QQ登录成功后，分配给网站的appkey。
        # code            必须      上一步返回的authorization
        # redirect_uri    必须      与上面一步中传入的redirect_uri保持一致。

        #1.获取code
        code = request.query_params.get('code')

        if code is None:
            return Response(status=400)

        qq = QQOauth()

        access_token = qq.get_access_token(code)

        openid = qq.get_openid(access_token)

        #根据openid来判断 用户是否绑定过
        try:
            qquser = OAuthQQUser.objects.get(openid=openid)
        except OAuthQQUser.DoesNotExist:
            #第一次绑定需要授权

            token = OAuthQQUser.genericte_openid_token(openid)

            return Response({'access_token':token})
        else:
            #已经绑定过，直接登陆，返回token
            # 生成已登录的token
            jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER
            jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER
            user = qquser.user
            payload = jwt_payload_handler(user)
            token = jwt_encode_handler(payload)

            response = Response({
                'token': token,
                'user_id': user.id,
                'username': user.username
            })

        print(access_token)
        return response



    def post(self,request):
        #创建序列化器
        serializer = OauthQQSerializer(data=request.data)
        #进行校验
        serializer.is_valid(raise_exception=True)
        #数据保存
        user = serializer.save()
        #返回登陆的token
        jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER
        jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER

        payload = jwt_payload_handler(user)
        token = jwt_encode_handler(payload)

        response = Response({
            'token': token,
            'user_id': user.id,
            'username': user.username
        })
        return response


from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
#初始化对象
#第一个参数是screct,第二个是时间
s = Serializer('123',3600)
#第二步，将关键数据进行处理
dict = {
    'userid':1,
    'username':'itheima'
}
token = s.dumps(dict)

s.loads(token)

#校验
#初始化对象
#第一个参数是screct,第二个是时间
s = Serializer('123',1)
#第二步，将关键数据进行处理
dict = {
    'userid':1,
    'username':'itheima'
}
token = s.dumps(dict)

s.loads(token)